<template>
  <div>
    <h1>App 根组件</h1>
    <hr>
    <!-- 使用表格组件 -->
    <my-table :data="goodslist">
      <!-- 表格的标题 -->
      <template v-slot:header>
        <th>#</th>
        <th>商品名称</th>
        <th>价格</th>
        <th>标签</th>
        <th>操作</th>
      </template>
      <!-- 表格每行的单元格 -->
      <template v-slot:body="{ row, index }">
        <td>{{ index + 1 }}</td>
        <td>{{ row.goods_name }}</td>
        <td>￥{{ row.goods_price }}</td>
        <td>
          <!-- 基于当前行的 inputVisible，来控制 input 和 button 的按需展示-->
          <input type="text" class="form-control form-control-sm ipt-tag" v-if="row.inputVisible" v-focus v-model.trim="row.inputValue" @blur="onInputConfirm(row)" @keyup.enter="onInputConfirm(row)" @keyup.esc="row.inputValue = ''">
          <button type="button" class="btn btn-primary btn-sm" v-else @click="row.inputVisible = true">+Tag</button>
          <span class="badge badge-warning ml-2" v-for="item in row.tags" :key="item">{{item}}</span>
        </td>
        <td>
          <button type="button" class="btn btn-danger btn-sm" @click="onRemove(row.id)">删除
        </button>
        </td>
      </template>
    </my-table>
  </div>
</template>
<script>
// 导入 MyTable 组件
import MyTable from './components/my-table/MyTable.vue'
export default {
  name: 'MyApp',
  data() {
    return {
      goodslist: [] // 商品列表数据
    }
  },
  methods: {
    async getGoodsList() {  // 初始化商品列表的数据
      const { data: res } = await this.$http.get('/api/goods')  // 发起 Ajax 请求
      // 请求失败
      if (res.status !== 0) return console.log('获取商品列表失败！')
      // 请求成功
      this.goodslist = res.data
    },
    onRemove(id) {  // 根据 Id 删除商品信息
      this.goodslist = this.goodslist.filter(x => x.id !== id)
    },
    onInputConfirm(row) {
      const val = row.inputValue  // 1. 把用户在文本框中输入的值，预先转存到常量 val 中
      row.inputValue = '' // 2. 清空文本框的值
      row.inputVisible = false  // 3. 隐藏文本框
      // 1.1 判断 val 的值是否为空，如果为空，则不进行添加
      // 1.2 判断 val 的值是否已存在于 tags 数组中，防止重复添加
      if (!val || row.tags.indexOf(val) !== -1) return
      // 2. 将用户输入的内容，作为新标签 push 到当前行的 tags 数组中
      row.tags.push(val)
    }
  },
  created() {
    this.getGoodsList()
  },
  components: { // 注册 MyTable 组件
    MyTable
  },
  directives: {
    focus(el) { // 封装自动获得焦点的指令
      el.focus()
    },
  }
}
</script>
<style lang="less" scoped>
.ipt-tag {
  display: inline;
  width: 80px;
}
</style>